草庐IT

C++ STL : Custom sorting one vector based on contents of another

全部标签

c++ - 您是否必须在类似 STL 的类中实现多个迭代器?

我非常熟悉STL及其使用方法。我的问题是...如果我要实现自己的STL容器类型,如何定义内部迭代器?STL类往往具有顺序或随机访问迭代器、它们的const_版本和流迭代器。这些迭代器是否在每个STL类中都已完全定义,或者是否存在您从中继承的某种基类以获得大部分迭代器功能?有谁知道有关如何实现支持这些不同类型的迭代器的类的良好引用? 最佳答案 一般来说,你只需要实现iterator和const_iterator.如果需要反向迭代器,可以使用std::reverse_iterator的实例化.流迭代器将使用operator>>和oper

c++ - STL 中的比较器

我正在使用structminHeap生成一个使用priority_queue的最小堆。并且函数comp使用STL中给出的排序函数以相反的顺序打印数字。现在我的疑问是我不能在函数sort中使用structminHeap并且不能在priorityQueue中使用函数comp。感觉structminHeap和comp的功能差不多。请解释一下何时使用比较器的结构以及何时使用普通函数作为STL中的比较器?#include#include#include#includeusingnamespacestd;structminHeap{booloperator()(constinta,constint

c++ - 切换到C++11时,是否需要重新编译接口(interface)中使用STL的所有依赖库?

我正在尝试将一个大型项目切换为使用C++11。我遇到了大量链接器错误,这些错误似乎是由使用C++11编译的库和使用C++03编译的库之间的STL类上不匹配的命名空间引起的。例如,假设库B是A的依赖项。B具有以下模板化类作为其接口(interface)的一部分。templateclassVectorParameter{public:VectorParameter();virtual~VectorParameter();...}库A使用VectorParameter>实例化模板.当我用C++11重新编译A而没有重新编译B时,我遇到了链接器错误并提示LFE::VectorParameter>

C++ STL 问题 : allocators

我有一个(可能是愚蠢的)关于C++STL的问题。当我创建一个容器(vector、set、map等)时,它是分配在栈上还是堆上?如果我制作一个集合并放入500万个字符串,我是否需要担心堆栈溢出? 最佳答案 STL类默认从堆中分配其内部缓冲区,尽管这些类也允许自定义分配器,允许用户指定备用位置进行分配-例如共享内存池。 关于C++STL问题:allocators,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.c

c++ - 对列表串联(STL)进行排序的有效方法,合并排序提示,部分排序

我有一种情况,我得到一个已经部分排序的值列表。我的最终列表中有N个block,每个block都已排序。所以我最终得到了这样的数据列表(斜杠只是为了强调):12345678/12345/23456789/1234我将这些作为一系列指向对象的指针放在vector中。目前我只是将std::sort与自定义比较器一起用于排序。我猜这是次优的,因为我的序列是一些退化的情况。是否有任何其他STL函数、提示或其他我可以用来提供此类数据的最佳排序?(Boost库也很好)。虽然我不能轻易地分解输入数据,但我当然可以确定子序列从哪里开始。 最佳答案 你

c++ - 为什么 nullptr 是核心语言的一部分,而 nullptr_t 是 STL 的一部分?

据我所知nullptr是核心语言的一部分。引用C++11:(18.2/9)nullptr_tisdefinedasfollows:namespacestd{typedefdecltype(nullptr)nullptr_t;}并在header中定义. 最佳答案 因为它可以。C++标准化过程的一个中心目标是在向语言添加内容时尽可能少地改变核心语言。nullptr篡改了0的用法来表示空指针和,呃,零。由于显而易见的原因,使用0导致问题,f(0)调用f(int)还是f(int*)?于是在核心语言中加入了一个全新的字面量:nullptr。它

c++ - STL 中 next_permutation 的 Python 实现

next_permutation是一个C++函数,它按字典顺序给出字符串的下一个排列。有关其实现的详细信息可以从这篇非常棒的帖子中获得。http://wordaligned.org/articles/next-permutation有人知道Python中的类似实现吗?STL迭代器是否有直接的Python等价物? 最佳答案 itertools.permutations很近;最大的区别是它将所有项目视为唯一而不是比较它们。它也不会就地修改序列。在Python中实现std::next_permutation对您来说可能是一个很好的练习(在

c++ - 斐波那契堆的 STL?

STL中的斐波那契堆在哪里?如果STL不实现Fibonacci堆,最佳实践是什么使用STL中的现有算法和容器来实现它? 最佳答案 boost有animplementationofit.希望有所帮助。STL里好像没有.这是一个例子:for(intn=0;n 关于c++-斐波那契堆的STL?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/14118367/

c++ - STL 迭代器 std::distance() 错误

我有这样两个类型定义:typedefstd::vectorContainer;typedefstd::vector::const_iteratorIter;在我考虑的问题中,我对ContainerInput进行了一些操作,然后我想计算std::distance(Input.begin(),itTarget),其中itTarget属于Iter类型。但是我得到了这个编译器错误noinstanceoffunctiontemplate"std::distance"matchestheargumentlist,并且仅在类型转换之后,即std::distance(static_cast(Input

c++ - 使用STL从字符串中删除重复字符

有没有办法从字符串中删除重复的字符,就像它们可以从vector中删除一样,如下所示sort(vec.begin(),vec.end());vec.erase(unique(vec.begin(),vec.end()),vec.end());还是我只需要为它编写一个基本的解决方案?我的想法:我可以把所有的角色都加到一个集合中 最佳答案 C++算法和容器设计的全部要点在于算法——尽可能——与容器无关。因此,适用于vector的相同算法当然有效!–在字符串上。std::sort(str.begin(),str.end());str.era